home *** CD-ROM | disk | FTP | other *** search
/ Internet 53 / INTERNET53.iso / mac / SOFTWARE / MAC / MULTIMEDIA / SOUNDEFFECTS / SOUNDEFFECTS-092.HQX / SoundEffects 0.9.2 %c4 / SoundEffects Developer%d5s Kit / Writing SoundEffects Effects < prev    next >
Text File  |  1997-07-06  |  12KB  |  235 lines

  1. Writing SoundEffects effect modules
  2. ---------------------------------------------------------------------------------
  3. ©1994 Alberto Ricci <aricci@kagi.com> <fricci@polito.it>
  4.       Home page: http://www.silene.it/aricci/
  5.  
  6.  
  7. MODULE STRUCTURE
  8.  
  9. Your effect module file must be of type '√Eff' and creator '√SFx'. The √ symbol
  10. is obtained by typing option-v.
  11.  
  12. SoundEffects calls your module by passing it four parameters:
  13. - a message (OSType) specifying which action to perform.
  14. - information on the sound (ModParamsPtr).
  15. - pointers to 68000 callback routines (GluePtr).
  16. - pointers to PowerPC callback routines (GluePtr).
  17.  
  18. To simplify things, a file called “Glue.c” is included in the SoundEffects
  19. Developer’s Kit. You should add this file to your project, so you don’t need
  20. to handle all the messages yourself: just write your own effect(), settings()
  21. and about() routines, as explained below.
  22.  
  23. To make your life even easier, two “empty” effect projects (Symantec C 7.0 and
  24. Metrowerks CodeWarrior 1.1) are included. Just make a copy of, rename it, and
  25. insert your code where needed.
  26.  
  27.  
  28. BUILDING THE MODULE
  29.  
  30. If your module doesn’t need a custom About… dialog, and uses the standard
  31. resources (as described below under “About Window resources”), add the file
  32. “ModNoAbout.c” to your project.
  33.  
  34. If your module doesn’t have any parameters or doesn’t need to save any settings,
  35. add the file “ModNoSettings.c” to your project.
  36.  
  37. Definitions of the structures and constants used in this document can be found
  38. in the header file “Glue.h” distributed with the SoundEffects Developer’s Kit.
  39. This file also contains all the prototypes you’ll need.
  40.  
  41. The header file “Glue.h” is commented, so take a look at it for specific
  42. information.
  43.  
  44. If you use the supplied “Glue.c” file, you can also use global variables
  45. throughout your code.
  46.  
  47.  
  48. RESOURCES
  49.  
  50. •    effect code resources are of type 'EFCT'.
  51. •    put any error messages (which are reported with (*glue->ModShowError)() or by
  52.     returning a value ≠ noErr and ≠ kModCancel to the application) into a
  53.     'STR#' resource, ID = 1000.
  54. •    always put one 'mInf' resource, any ID. A template for this resource type is
  55.     included with the SoundEffects Developer’s Kit.
  56.     In this resource, specify the minimum amount of RAM you want available before
  57.     running and the oldest header version your effect supports (see below,
  58.     “Header Versions”).
  59.  
  60.  
  61. OPTIONAL RESOURCES
  62.  
  63. •    if you add a resource of type 'EFCF' to a module, and an FPU is present, that
  64.     code resource will be called instead of the 'EFCT' one, with the same parameters.
  65. •    if you add a resource of type 'EFCP' to a module, and SoundEffects is running
  66.     on a Power Mac, that code resource will be called instead of the 'EFCT' one,
  67.     with the same parameters.
  68. •    put any picture and/or text (shareware notices, author info, etc.) you want
  69.     to be displayed in the Progress window when the module is running into a
  70.     PICT and/or TEXT resource, ID = 1001.
  71. •    If you want your effect to appear in a submenu of the “Effects” menu in
  72.     SoundEffects, add a resource of type 'Grup', any ID, containing the name
  73.     of the submenu. The format of this resource is identical to that of a 'STR '
  74.     resource, and a template is included with the Developer’s Kit.
  75.  
  76.  
  77. ABOUT WINDOW RESOURCES
  78.  
  79. •    put any copyright info into a 'STR ' resource, ID = 1000, and it will be
  80.     displayed in the effect’s about dialog (shown when choosing the effect with
  81.     the shift key down).
  82. •    put a description of the effect into a 'TEXT' resource, ID = 1000, which will be
  83.     displayed in the effect’s about dialog.
  84. •    put any version info into a 'vers' resource, ID = 1, and it will be displayed in
  85.     the effect’s about dialog.
  86. •    if you want a custom window size for the about dialog, add a 'nrct' resource,
  87.     ID = 1000, containing the rect of the window in the first rectangle field.
  88. •    if you want to add a picture to the window, add it as a 'PICT' resource,
  89.     ID = 1000, and put the rect in which it should appear in the second rectangle
  90.     field in the 'nrct' resource, ID = 1000.
  91.     If you don’t add this rectangle to the 'nrct' resource, the picture’s rectangle
  92.     will be used.
  93.     If you add the rectangle to the 'nrct' resource, but it is empty (top = bottom
  94.     and left = right), the picture’s rectangle will be used, and the top left corner
  95.     will be positioned at the top left corner of the empty rectangle.
  96.  
  97.  
  98. HEADER VERSIONS
  99.  
  100. SoundEffects determines whether an effect module is compatible with it by looking
  101. at two version numbers the module supplies:
  102. - the version number of the header file the module was compiled with, and
  103. - the oldest version number of the header file the module requires.
  104.  
  105. For example, suppose the version of the headers you are using is version 10.
  106. In the headers file, it is specified which callbacks were introduced in which
  107. version.
  108. Let’s suppose in your module you don’t use any callbacks that were introduced in
  109. versions 8 or higher: all the callbacks you use are labeled as “Version 1...7
  110. Callbacks” in the header file. In this case, you’d specify 7 as the oldest supported
  111. headers version. This way, you tell SoundEffects that your module cannot run on
  112. versions of SoundEffects which do not support all the callbacks you use (in this
  113. case versions of SoundEffects that correspond to header versions 1 to 6).
  114.  
  115. You must specify the oldest version number of the header file in a 'mInf' resource,
  116. as described above in “Resources”.
  117.  
  118.  
  119. CALLBACKS
  120.  
  121. The pointers to the callback routines are passed to your module by SoundEffects in
  122. two parameters: glue68k and gluePPC. These two structures contain pointers to the
  123. same routines, but you will have to use glue68k if your code resource contains
  124. 680x0 code, and gluePPC if it contains native PowerPC code.
  125. If you use the file “Glue.c” supplied with the SoundEffects Developer’s Kit, this
  126. will be handled for you and your settings() and effect() routines will only receive
  127. the pointer to the one appropriate GlueRec structure.
  128.  
  129. In any case, you will always call the callbacks the same way:
  130. theResult = (*glue->TheCallback)(theParameters);
  131.  
  132. All the callbacks may move memory.
  133.  
  134. •    GetBytesToProcess        returns the number of selected bytes, taking into account
  135.                             every selected channel and its length.
  136. •    ModMaxChSize            returns the length (in bytes) of the longest channel.
  137. •    ModMaxRelChSize            takes the number of selected bytes in each channel
  138.                             and returns the greatest one.
  139. •    ModDoSettingsDialog        handles all the settings dialog automatically.
  140.                             Pass true in withSetups if you want to have a pop-up
  141.                             menu with common used settings in the dialog. Everything
  142.                             will be handled by this single callback.
  143.                             Pass an ItemInfoHandle containing a description of each
  144.                             dialog item to the callback.
  145.                             See the sample module “Settings Test” for details.
  146. •    ModGetSampleValueLimits    returns the maximum and minimum value allowed for a sample
  147.                             with the current bps value.
  148.  
  149.  
  150. PROGRESS BAR
  151.  
  152. • Call (*glue->ModSetupProgress)() early in your module to specify which string you
  153. want to display in the progress bar and to start animating the watch cursor.
  154. • pass it a pointer to a short variable. This variable MUST be either a global
  155. variable or one that won’t be disposed of before ModCloseProgress will be called.
  156. Whenever you have time in your loop, check the value of this variable: if it is not
  157. zero, you should call (*glue->ModShowProgress)().
  158. • Pass ModShowProgress two parameters to indicate at what point you are in process.
  159. For example, pass percentageDone and 100, or processedSamples and
  160. totalSamplesToProcess. Pass 0xFFFFFFFF in the first parameter if you can’t tell
  161. in which point you are of the effect process. In this case, a striped bar will
  162. be shown.
  163. Also pass it a pointer to the “timeToCallProgress” short variable. It will reset
  164. it to zero.
  165. • ModShowProgress returns a OSErr value. If the user clicks the Stop button, this
  166. value will be kModCancel, and the module should clean up and exit. If possible, it
  167. should restore the original data. If this can’t be done or is too much work, pass
  168. false in the canCancel parameter, otherwise pass true.
  169. • ALWAYS call (*glue->ModCloseProgress)() before exiting.
  170.  
  171. • If you don’t want to show a progress window, you can still call ModSetupProgress
  172. and then ModCloseProgress to show the spinning watch cursor.
  173.  
  174. • You can pass 0L to ModSetupProgress in the textStr or in the modInfo parameters,
  175. but not in the timeToCallProgress parameter.
  176.  
  177.  
  178. RECORDS, PARAMETERS AND VARIABLES
  179.  
  180. •    All selection bounds and sound sizes are passed in bytes, not samples.
  181.     If modInfo->selSt is 0L and modInfo->selEnd is 5000L, it means the first byte
  182.     you are allowed to touch is the one at (*myChannelHandle + 0L), and the last one
  183.     if (*myChannelHandle + 4999L), not the 5000th.
  184.     The number of selected bytes is, of course, modInfo->selEnd - modInfo->selSt, in
  185.     this case 5000.
  186. •    You can obtain the size of one sample, in bytes, with:
  187.     sampleSize = modInfo->bps/8 + (modInfo->bps%8 != 0);
  188. •    modInfo->firstSelCh and modInfo->lastSelCh values range from 1 to
  189.     modInfo->numChans.
  190. •    An SEChanHandle is passed to your module inside the ModParamsRec record. This
  191.     handle contains the handles to the document’s channels and their sizes.
  192.     The handle to channel number ch is, for example:
  193.     myChannelHandle = (*modInfo->hands)[channelNumber].chan;
  194.     and the size of that channel, in bytes, is:
  195.     myChannelSize = (*modInfo->hands)[channelNumber].size;
  196. •    The ModParamsRec should contain everything you need to know about the sound:
  197.     a pointer to the window (parentWind), the selection bounds (selSt, selEnd,
  198.     firstSelCh, lastSelCh), the number of channels (numChans), the sample size
  199.     (bps), the sampling rate (rate), the loop bounds (loopSt, loopEnd), the
  200.     currently selected units (units - see the file “ModUnits.h”).
  201. •    The doExtend field of the ModParamsRec record contains 1 if the user wants
  202.     you to enlarge the sound as necessary when your effect needs to do that;
  203.     0 if the user wants the selection to have the same length as before applying
  204.     the effect, or 2 if he wants to decide each time. So, if you’re going to
  205.     modify the length of the selection or if you may change the sound outside
  206.     the selection, and modInfo->doExtend is 2, call (*glue->AskDoExtend)().
  207.     This callback will return either true (extend) or false (don’t extend the
  208.     selection).
  209. •    The short integers returned by (*glue->ModGetChannelPan)() are formatted as
  210.     volumes in the new SoundManager 3.0. They are fixed-point values, where the
  211.     high byte is the integer part and the low byte is the fractional part.
  212.     0x0100 (kFullVolume)    is full volume (you can overdrive the channel by setting
  213.                             the value to more than 1.0),
  214.     0x0080                    is half volume, and
  215.     0x0000                    is silent.
  216.     All negative values are silent.
  217. •    The reference number for the module file is contained in the refNum field of
  218.     the ModParamsRec record, modInfo->refNum.
  219.  
  220.  
  221. RESULT CODES
  222.  
  223. When the module is called, it should perform only the requested action and then
  224. exit, returning a OSErr value. This value should be:
  225. - kModNoError            if the effect ran succesfully and some data was modified.
  226. - kModCancel            if the effect left everything untouched.
  227. - any positive value    if an error occurred and some data was modified.
  228.                         SoundEffects will take care of alerting the user about
  229.                         this, and it will use the corresponding string in the
  230.                         module’s 'STR#' resource, ID = 1000, as an error message.
  231. - any negative value    if an error occurred and nothing was changed.
  232.                         SoundEffects will use the corresponding positive string
  233.                         in the module’s 'STR#' resource, ID = 1000, as an error
  234.                         message.
  235.